Amendment submitted with RCE of May 27, 2005

## IN THE CLAIMS

This listing of claims will replace all prior versions, and listings, of claims in the application:

## **Listing of Claims:**

1. (Currently amended) A method of <u>simultaneously</u> optimizing <u>code for</u> at least two target machines, comprising the steps of:

abstracting a rule of instruction scheduling for each of said at least two target machines;

generating a hypothetical machine based on said rule of instruction scheduling for each of said at least two target machines, wherein a different rule of instruction scheduling for said hypothetical machine is a restrictive set of said rule of instruction scheduling for each of said at least two target machines; and

targeting said hypothetical machine.

- 2. (Cancelled)
- (Previously presented) The method of claim 1 further including the steps of: detecting a conflict between said rule of instruction scheduling for each of said at least two target machines; and

resolving said conflict.

- 4. (Previously presented) The method of claim 3 wherein said step of resolving said conflict includes a step of selecting a less damaging option for said detected conflict.
- 5. (Previously presented) The method of claim 3 wherein said detected conflict corresponds to an inherent conflict between said rule of instruction scheduling for each of said at least two target machines.
- 6. (Original) The method of claim 1 further including the steps of: modeling each of said at least two target machines; and retrieving scheduling information corresponding to each of said at least two target machines.
- 7. (Original) The method of claim 1 wherein said at least two target machines include an UltraSPARC-II configured to operate at a speed of 360 MHz and an UltraSPARC-III configured to operate at a speed of 600 MHz.
- 8. (Currently amended) A method of <u>simultaneously</u> optimizing <u>code for</u> at least two target machines, comprising the steps of:

retrieving scheduling information corresponding to each of said at least two target machines;

abstracting a rule of instruction scheduling for each of said at least two target machines;

generating a hypothetical machine based on said rule of instruction scheduling for each of said at least two target machines, wherein a different rule of instruction scheduling

**PATENT** 

Appl. No. 09/823,207

Amdt. dated May 27, 2005

Amendment submitted with RCE of May 27, 2005

for said hypothetical machine is a restrictive set of said rule of instruction scheduling for each of said at least two target machines; and

targeting said hypothetical machine.

9. (Previously presented) The method of claim 8 further including the steps of: detecting a conflict between said rule of instruction scheduling for each of said at

least two target machines; and

resolving said conflict.

- 10. (Cancelled)
- 11. (Previously presented) The method of claim 9 wherein said step of resolving said conflict includes a step of selecting a less damaging option for said detected conflict.
- 12. (Previously presented) The method of claim 9 wherein said detected conflict corresponds to an inherent conflict between said rule of instruction for each of said at least two target machines.
- 13. (Currently amended) An apparatus for <u>simultaneously</u> optimizing <u>code for</u> at least two target machines, comprising:

means for abstracting a rule of instruction scheduling for each of said at least two target machines;

means for generating a hypothetical machine based on said rule of instruction scheduling for each of said at least two target machines, wherein a different rule of

instruction scheduling for said hypothetical machine is a restrictive set of said rule of instruction scheduling for each of said at least two target machines; and means for targeting said hypothetical machine.

- 14. (Cancelled)
- 15. (Previously presented) The apparatus of claim 13 further including:

  means for detecting a conflict between said rule of instruction scheduling for each

  of said at least two target machines; and

  means for resolving said conflict.
- 16. (Previously presented) The apparatus of claim 15 wherein said resolving means includes means for selecting a less damaging option for said detected conflict.
- 17. (Previously presented) The apparatus of claim 15 wherein said detected conflict corresponds to an inherent conflict between said rule of instruction scheduling for each of said at least two target machines.
- 18. (Original) The apparatus of claim 13 further including:

  means for modeling each of said at least two target machines; and

  means for retrieving scheduling information corresponding to each of said at least
  two target machines.
- 19. (Currently amended) An apparatus for <u>simultaneously</u> optimizing <u>code for</u> at least two target machines, comprising:

means for retrieving scheduling information corresponding to each of said at least two target machines;

means for abstracting a rule of instruction scheduling for each of said at least two target machines;

means for generating a hypothetical machine based on said rule of instruction scheduling for each of said at least two target machines, wherein a different rule of instruction scheduling for said hypothetical machine is a restrictive set of said rule of instruction scheduling for each of said at least two target machines; and means for targeting said hypothetical machine.

20. (Currently amended) An apparatus for <u>simultaneously</u> optimizing <u>code for</u> a plurality of target machines, comprising:

means for modeling a plurality of target machines;

means for retrieving scheduling information corresponding to each of said plurality of target machines;

means for abstracting a rule of instruction scheduling for each of said plurality of target machines;

means for generating a hypothetical machine based on said rule of instruction scheduling for each of said plurality of target machines, wherein a different rule of instruction scheduling for said hypothetical machine is a restrictive set of said rule of instruction scheduling for each of said plurality of target machines;

means for targeting target said hypothetical machine;

means for detecting a conflict between said rule of instruction scheduling for each of said plurality of target machines; and

means for resolving said conflict.